## Laboratory 2

(Due date: 002/003: February 4th, 004: February 5th, 005: February 6th)

## **OBJECTIVES**

- ✓ Use the Structural Description on VHDL.
- ✓ Test arithmetic circuits on an FPGA.

## VHDL CODING

✓ Refer to the <u>Tutorial: VHDL for FPGAs</u> for a list of examples.

## FIRST ACTIVITY (100/100)

• **PROBLEM**: BCD Addition of two numbers. The operands (*A* and *B*) are 4-bit numbers represented in BCD (where only numbers from 0 to 9 are allowed). The result *S* is also represented in BCD. There is also a BCD carry out (*cout*). If any of the operands is greater than 9, the result *S* is invalid.

Example: 7 + 8 = 15. Here, cout = 1, and S = 0101 = 5.

This circuit can be built out of two 4-bit binary adders and a few logic gates as depicted in the figure  $\Rightarrow$ 

✓ Operation: If  $A + B > 9 \rightarrow S = 6 + Z$ , *cout* = 1. Here, by adding 6, we "correct" the binary sum to make it look as BCD code. If  $A + B \le 9 \rightarrow S = Z$ , *cout* = 0.



• The figure below depicts the internal architecture of the 4-bit binary adder. The full adder circuit is also shown.



- ✓ NEXYS A7-50T: Create a new Vivado Project. Select the XC7A50T-1CSG324 Artix-7 FPGA device.
- ✓ Write the VHDL code for the BCD Adder. Use the Structural Description: Create a separate file for the Full Adder, the 4-bit adder, the 'CMP' block, and the top file (BCD Adder).
- ✓ Write the VHDL testbench to test the circuit for the following cases:
  - ▲=0x9, B=0x8, cin=0 → cout=1, S=0111
  - ▲=0x6, B=0x7, cin=1 → cout=1, S=0100
  - ▲=0x5, B=0x6, cin=1 → cout=1, S=0010
  - ▲=0x3, B=0x6, cin=0 → cout=0, S=1001
  - ▲=0x9, B=0x1, cin=0 → cout=1, S=0000



- ✓ Perform <u>Functional Simulation</u> and <u>Timing Simulation</u> of your design. **Demonstrate this to your TA**.
- ✓ I/O Assignment: Create the XDC file. Nexys A7-50T: Use SW15-SW0 for the inputs, and LED4-LED0 for the outputs.
- ✓ Generate and download the bitstream on the FPGA and test. **Demonstrate this to your TA**.
- Submit (as a .zip file) the five generated files: VHDL code (4 files), VHDL testbench, and XDC file to Moodle (an assignment will be created). DO NOT submit the whole Vivado Project.

TA signature: \_

Date: \_

1